草庐IT

php整数和 float 比较不匹配

全部标签

ruby - 在 Ruby 中舍入到最接近的整数或最接近的 .5

可能标题比较乱,我会尽量用例子来解释:给定一个精度为2的float,我希望能够四舍五入到它的闭整数,或者最接近的.5。示例:Given:4.12-->44.24-->44.25-->4.54.33-->4.54.53-->4.54.65-->4.54.75-->54.84-->5在Ruby中执行此操作的好方法是什么? 最佳答案 乘以2,四舍五入,除以2。[4.12,4.24,4.25,4.33,4.53,4.65,4.75,4.84].mapdo|x|r=(x*2).round/2.0r.to_i==r?r.to_i:rend=>[

ruby - 如何将 unicode 单词与 ruby​​ 1.9 匹配?

我正在使用ruby​​1.9并试图找出我需要哪个正则表达式来实现这一点:Encoding.default_internal=Encoding.default_external='utf-8'"föö".match(/(\w+)/u)[1]=="föö"#=>false 最佳答案 #encoding=utf-8p"föö".match(/\p{Word}+/)[0]=="föö" 关于ruby-如何将unicode单词与ruby​​1.9匹配?,我们在StackOverflow上找到一个类

ruby - 模式匹配时 =~ 和 match() 有什么区别?

我正在使用Ruby1.9.3。我在玩一些模式,发现了一些有趣的东西:示例1:irb(main):001:0>/hay/=~'haystack'=>0irb(main):003:0>/st/=~'haystack'=>3示例2:irb(main):002:0>/hay/.match('haystack')=>#irb(main):004:0>/st/.match('haystack')=>#=~返回其第一个匹配项的第一个位置,而match返回模式。除此之外,=~和match()还有什么区别吗?执行时间差(根据@Casper)irb(main):005:0>quickbm(10000000

ruby - 如何排除匹配特定标签的 RSpec 测试?

从命令行运行我的RSpec测试时,如何排除与特定标记匹配的测试? 最佳答案 在标签名称中使用~@,如下所示:rspecspec--tag~@slow查看文档:https://www.relishapp.com/rspec/rspec-core/docs/command-line/tag-option更新我现在正在Spork上运行我的测试,它似乎忽略了这个指令。不知道为什么。 关于ruby-如何排除匹配特定标签的RSpec测试?,我们在StackOverflow上找到一个类似的问题:

从 float 转换的 Ruby Time 对象不等于原始 Time 对象

time=Time.nowfvalue=time.to_freturntime==Time.at(fvalue)这里有人可以解释为什么上面的表达式返回false吗?如何从与原始时间变量匹配的float创建新的时间对象?谢谢 最佳答案 IEEE754double(由to_f返回)不够准确,无法表示确切时间。t1=Time.nowf1=t1.to_ft2=Time.at(f1)#theylookthesamet1.inspect#=>'2013-09-0923:46:08+0200't2.inspect#=>'2013-09-0923:

ruby - 如何在 Ruby 中获取字符串匹配正则表达式的特定部分?

我有一个字符串Unnecessary:12357927251data并且我需要选择冒号和数字之后的所有数据。我将使用Regexp来完成。string.scan(/:\d+.+$/)这会给我:12357927251data,但是我可以只选择需要的信息.+(data)吗? 最佳答案 正则表达式中括号中的任何内容都将被捕获为一个组,您可以在$1、$2等中或使用[]在匹配对象上:string.match(/:\d+(.+)$/)[1]如果将扫描与捕获组一起使用,您将获得一组数组:"Unnecessary:123data\nUnnecessa

ruby-on-rails - 将用户输入转换为整数

所以我有一个用户可以输入价格的表单。我正在尝试制作一个before_validation来规范化数据,如果用户输入它,则剪掉$。before_validationdounlessself.price.blank?thenself.price=self.price.to_s.gsub(/\D/,'').to_iendend如果用户输入$50此代码给我0。如果用户输入50$此代码给我50。我认为由于数据类型是整数,所以Rails在我的before_validation之前运行.to_i并在$之后剪切所有内容。如果数据类型是字符串,同样的代码也能正常工作。有人有解决方案可以让我保留整数数据类

ruby - 如何干净地验证用户输入是否是 Ruby 中的整数?

我有一段代码,我要求用户输入一个数字作为我问题的答案。我可以执行to_i但棘手/垃圾输入会通过to_i逃逸。例如,如果用户输入693iirum5作为答案,#to_i会将其剥离为693。请建议一个函数,而不是正则表达式。预先感谢您的回复。 最佳答案 这将验证输入:Integer(gets)rescuenil 关于ruby-如何干净地验证用户输入是否是Ruby中的整数?,我们在StackOverflow上找到一个类似的问题: https://stackoverfl

ruby-on-rails - Ruby 排序依据(整数) "comparison of NilClass with 3200 failed"

我想在Rails应用程序中对我的记录进行排序:@ebms=Ebm.all@ebms.sort_by!{|u|u.number}u.number被定义为整数!问题是Rails无法将它与nil进行比较:comparisonofNilClasswith32400failed我该怎么做才能避免这个错误? 最佳答案 尝试将nil转换为整数怎么样?@ebms=Ebm.all@ebms.sort_by!{|u|u.number.to_i} 关于ruby-on-rails-Ruby排序依据(整数)"co

ruby - 在一行中查找不区分大小写的单词匹配项

我需要查找一行中出现的所有单词,但搜索必须不区分大小写。我还需要向我的正则表达式添加什么?arr=line.scan(/\s+#{word}\s+/) 最佳答案 你需要修饰符/iarr=line.scan(/\b#{word}\b/i)http://www.tutorialspoint.com/ruby/ruby_regular_expressions.htm最好使用\b作为单词边界,因为正则表达式中的第二个\s+eats空格,可用于另一个匹配词的第一个\s+;您的正则表达式在行首和行尾也失败:>"asdasdasdasd".sca